## **دستور کار آزمایشگاه مجازی مدارهای منطقی و معماری کامپیوتر**

## کامپیوتر پایه دارای ویژگیهای زیر است:

- هشت عدد رجیستر ۸ بیتی به نامهای R<sub>0</sub> تا R<sub>7</sub> این رجیستر بانک دارای دو پورت برای خواندن و یک پورت برای نوشتن است و خواندن از آن به صورت آسنکرون و نوشتن در آن به صورت سنکرون با کلاک و در لبه بالارونده کلاک است. این رجیستر بانک باید توسط دانشجویان در یک ماژول کد زده شود و در ماژول اصلی از آن نمونه گرفته و با آن کار شود.
- حافظه دستور (Instruction memory که از این پس IM گفته می شود) به اندازه ۲۵۶ خانه ۱۶ بیتی. (پس طول آدرس IM هشت بیتی خواهد بود یعنی PC هشت بیتی است. پعنی PC هشت بیتی است) همچنین با این حساب دستورات ۱۶ بیتی خواهند بود و در نتیجه Instruction Register) نیز ۱۶ بیتی است. دانشجویان می توانند برای IM از IP Core های آماده موجود در ISE استفاده کنند. توجه کنید که عناصر حافظه موجود در IP Core کلاک هستند. (پیشنهاد می شود دیتاشیت آنها را مطالعه مختصری کنید.)
- حافظه داده (Data Memory که از این پس به آن DM گفته می شود) به اندازه ۲۵۶ خانه ۸ بیتی. (پس طول آدرس DM هم هشت بیتی خواهد بود) DM نیز همانند IM از Coreها استفاده می شود. بدیهی است که باید از ماژول های IM و DM هم نمونهای گرفته شود و سیگنالهای ورودی و خروجی آن به جاهای مناسب وصل شود.
- دیتا باس ۸ بیتی. یعنی همه کار با دادهها به صورت بیتی انجام میشود. (طول رجیسترها، عرض DM و طول دادههایی که به صورت مستقیم داده میشوند همگی ۸ بیتی است)
- کامپیوتر دارای ۴ فلگ است (CF-ZF-SF-OF) که این فلگها بعد از انجام بعضی از دستورات به روز می شوند. این که چه دستوری کدام فلگ را تحت تاثیر قرار می دهد در جدولی که در ادامه آمده است گفته می شود.
- کامپیوتر به صورت دو عملوندی است. این دو عملوند یا هر دو رجیستر هستند یا یکی رجیستر و دیگری یا آدرس (می تواند آدرس IM یا IM باشد) است یا داده. بیت MSB دستورات اگر ۰ باشد دستور از نوع دو رجیستری یا یک رجیستر و یک دیتا ۳ بیتی است و اگر ۱ باشد دستور از نوع یک رجیستر و دیگری دیتا یا آدرس است. در واقع در دستورات نوع اول دو عملوند ۳ بیتی هستند اما در دستورات نوع دوم عملوند اول ۳ بیتی و عملوند دوم ۸ بیتی است. این که قسمت عملوند دوم در نوع دوم دستورات آدرس IM یا آدرس DM و یا داده است از روی Opcode مشخص می شود و برای آن بیت اضافه ای در نظر گرفته نشده است. (به دلیل کم بودن تعداد بیت)

دستورات کامپیوتر به همراه Operandها هر دستور، تعریف آن، کد اسمبلی آن و این که هر دستور چه Flagهایی را تحت تاثیر قرار میدهد، در جدول زیر نشان داده شده است:

|   | Instru<br>ction | Operands | Description                                                                 | Flags Affected                       | assembly code             |
|---|-----------------|----------|-----------------------------------------------------------------------------|--------------------------------------|---------------------------|
| 1 | ADD             | REG, REG | operand1 = operand1 + operand2                                              | ALL Flags                            | 0-<br>000000001-<br>RRRRR |
| 2 | AND             | REG, REG | Logical AND between all bits of two operands. Result is stored in operand1. | OF=0<br>CF=0<br>SF,ZF are<br>updated | 0-<br>000000010-<br>RRRRR |
| 3 | SUB             | REG, REG | operand1 = operand1 - operand2<br>sub with 2's complement add               | ALL Flags                            | 0-<br>00000011-<br>RRRRR  |

|    |      | I               |                                                                                                                                                                                                                                 | 1                                                                                                                                    | -                                        |
|----|------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------|
| 4  | OR   | REG, REG        | Logical OR between all bits of two operands. Result is stored in operand1.                                                                                                                                                      | OF=0<br>CF=0<br>SF,ZF are<br>updated                                                                                                 | 0-<br>000000100-<br>RRRRR                |
| 5  | XOR  | REG, REG        | Logical XOR between all bits of two operands. Result is stored in operand1.                                                                                                                                                     | OF=0<br>CF=0<br>SF,ZF are<br>updated                                                                                                 | 0-<br>000000101-<br>RRRRRR               |
| 6  | MOV  | REG, REG        | Copy operand2 to operand1                                                                                                                                                                                                       | NONE                                                                                                                                 | 0-<br>000000110-<br>RRRRRR               |
| 7  | XCHG | REG, REG        | Exchange values of two operands                                                                                                                                                                                                 | NONE                                                                                                                                 | 0-<br>000000111-<br>RRRRRR               |
| 8  | NOT  | REG             | One's complement negate operand1 = ~ operand1                                                                                                                                                                                   | NONE                                                                                                                                 | 0-<br>000001000-<br>RRRXXX               |
| 9  | SAR  | REG , immediate | Shift Arithmetic operand1 Right. The number of shifts is set by operand2. Shift all bits right, the bit that goes off is set to CF. The sign bit that is inserted to the left-most position has the same value as before shift. | OF=0 if first<br>operand keeps<br>original sign.<br>the bit that goes<br>off is set to CF.<br>SF,ZF are<br>updated after<br>shifting | 0-<br>000001001-<br>RRRIII               |
| 10 | SLR  | REG , immediate | Shift operand1 Right. (Logical) The number of shifts is set by operand2. Shift all bits right, the bit that goes off is set to CF. Zero bit is inserted to the left-most position.                                              | OF=0 if first<br>operand keeps<br>original sign.<br>the bit that goes<br>off is set to CF.<br>SF,ZF are<br>updated after<br>shifting | 0-<br>000001010-<br>RRRIII               |
| 11 | SAL  | REG , immediate | Shift Arithmetic operand1 Left. The number of shifts is set by operand2. Shift all bits left, the bit that goes off is set to CF. Zero bit is inserted to the rightmost position.                                               | OF=0 if first<br>operand keeps<br>original sign.<br>the bit that goes<br>off is set to CF.<br>SF,ZF are<br>updated after<br>shifting | 0-<br>000001011-<br>RRR <mark>III</mark> |
| 12 | SLL  | REG , immediate | Shift operand1 Left. The number of shifts is set by operand2.  Shift all bits left, the bit that goes off is set to CF.  Zero bit is inserted to the rightmost position.                                                        | OF=0 if first<br>operand keeps<br>original sign.<br>the bit that goes<br>off is set to CF.<br>SF,ZF are<br>updated after<br>shifting | 0-<br>000001100-<br>RRRIII               |

| 13 | ROL          | REG , immediate                | Rotate operand1 right. The number of rotates is set by operand2. shift all bits right, the bit that goes off is set to CF and the same bit is inserted to the left-most position. | OF=0 if first<br>operand keeps<br>original sign.<br>the bit that goes<br>off is set to CF.<br>SF,ZF are<br>updated after<br>shifting | 0-<br>000001101-<br>RRRIII |
|----|--------------|--------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------|----------------------------|
| 14 | ROR          | REG , immediate                | Rotate operand1 left. The number of rotates is set by operand2. shift all bits left, the bit that goes off is set to CF and the same bit is inserted to the right-most position.  | OF=0 if first<br>operand keeps<br>original sign.<br>the bit that goes<br>off is set to CF.<br>SF,ZF are<br>updated after<br>shifting | 0-<br>000001110-<br>RRRIII |
| 15 | INC          | REG                            | operand = operand + 1. Increment<br>by 1                                                                                                                                          | ALL (same as ADD)                                                                                                                    | 0-<br>000001111-<br>RRRXXX |
| 16 | DEC          | REG                            | operand = operand - 1. Decrement by 1                                                                                                                                             | ALL (same as SUB)                                                                                                                    | 0-<br>000010000-<br>RRRXXX |
| 17 | NOP          | NONE                           | NONE                                                                                                                                                                              | NONE                                                                                                                                 | 0-<br>000000000-<br>XXXXXX |
| 18 | ShowR        | REG                            | Show Value of Register (operand) on LEDs                                                                                                                                          | NONE                                                                                                                                 | 0-<br>000010010-<br>RRRXXX |
| 19 | ShowR<br>seg | REG                            | Show Value of Register (operand) on 7 segments                                                                                                                                    | NONE                                                                                                                                 | 0-<br>000010011-<br>RRRXXX |
| 20 | СМР          | REG, REG                       | operand1 - operand2 Result is not stored anywhere, flags are set (OF, SF, ZF, CF) according to result.                                                                            | ALL                                                                                                                                  | 0-<br>000010100-<br>RRRRR  |
| 21 | JЕ           | Address of Data<br>Memory (IM) | address of memory that jumps to this if jump happened in operand2 and operand1 is don't care  Condition: ZF = 1                                                                   | NONE                                                                                                                                 | 1-0000-<br>XXXAAAA<br>AAAA |
| 22 | ЈВ           | Address of Data<br>Memory (IM) | Address of memory that jumps to this if jump happened in operand2 and operand1 is don't care.  Condition: CF = 1  Used for unsigned compare                                       | NONE                                                                                                                                 | 1-0001-<br>XXXAAAA<br>AAAA |
| 23 | JA           | Address of Data<br>Memory (IM) | Address of memory that jumps to this if jump happened in operand2 and operand1 is don't care.  Condition: CF = 0, ZF=0  Used for unsigned compare                                 | NONE                                                                                                                                 | 1-0010-<br>XXXAAAA<br>AAAA |
| 24 | JL           | Address of Data<br>Memory (IM) | Address of memory that jumps to this if jump happened in operand2 and operand1 is don't care.  Condition: SF not equal to OF  Used for signed compare                             | NONE                                                                                                                                 | 1-0011-<br>XXXAAAA<br>AAAA |

| 25 | JG  | Address of Data<br>Memory (IM)         | address of memory that jumps to this if jump happened in operand2 and operand1 is don't care Condition: SF=OF, ZF=0 Used for unsigned compare | NONE | 1-0100-<br>XXXAAAA<br>AAAA |
|----|-----|----------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|------|----------------------------|
| 26 | JMP | Address of Data<br>Memory (IM)         | Address of memory that jumps to this in operand2 and operand1 is don't care.  Jump without any condition                                      | NONE | 1-0101-<br>XXXAAAA<br>AAAA |
| 27 | LI  | REG , immediate                        | Copy immediate value (operand2) to Register (operand1)                                                                                        | NONE | 1-0110-<br>RRRIIIIIII      |
| 28 | LM  | REG, Address of<br>Data Memory<br>(DM) | Load data from data memory<br>(address of memory in operand2)<br>and copy to REG (operand1)                                                   | NONE | 1-0111-<br>RRRAAAA<br>AAAA |

## نكات مربوط به دستورات فوق:

- ۱. مقدار immediate در دستورات ۹ تا ۱۴ حداکثر ۸ است. به همین دلیل فیلد immediate در این دستورات ۳ بیتی است و همانند یک رجیستر فضا
   اشغال می کند. به همین دلیل این نوع دستورات را همانند REG-REG در نظر می گیریم. یعنی در این دستورات بیت MSB کد، صفر است.
  - ۲. از دستور ۲۱ دستورات نوع دوم (یکی از عملوندها ۳ بیتی و دیگری ۸ بیتی) شروع میشوند.
- ۳. در نمایش اسمبلی دستورات X به معنی A ،Don't care به معنی آدرس ( یا DM و یا R )، R به معنی آدرس یکی از رجسترها و A به معنی مقدار میباشد. این مقدار در بعضی از دستورات R بیتی و در بعضی از دستورات دیگر R بیتی است.